Exception.js ➔ Exception   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 3

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 2
CRAP Score 1

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
c 1
b 0
f 0
nc 1
nop 3
dl 0
loc 3
ccs 2
cts 2
cp 1
crap 1
rs 10
1
// Exception.js
2
"use strict";
3
4
// :: DEPENDENCIES
5
6
// load native dependencies
7 1
const path = require("path");
8
9
// load local dependencies
10 1
const Throwable = require(path.join(__dirname, "Throwable.js"));
11
12
// :: BASIC SETUP
13
14
/**
15
 * The class <tt>Exception</tt> and its subclasses are a form of <tt>Throwable</tt> that indicates conditions that a
16
 * reasonable application might want to catch.
17
 * @param {String} name - The name of the <tt>Exception</tt>.
18
 * @param {String} message - The message describing the <tt>Exception</tt>.
19
 * @param {Number} code - The unique code that identifies the cause of the <tt>Exception</tt>.
20
 * @augments Throwable
21
 * @constructor
22
 * @see https://docs.oracle.com/javase/8/docs/api/java/lang/Exception.html
23
 */
24 1
const Exception = function (name, message, code) {
25 8833
    Throwable.call(this, name, message, code);
26
};
27
28
// :: INHERITANCE
29
30
// set the prototype chain parent to the Throwable 'class'
31 1
Exception.prototype = Object.create(Throwable.prototype);
32
33
// set the prototype chain constructor
34 1
Exception.prototype.constructor = Exception;
35
36
// :: PROTOTYPE
37
38
/**
39
 * The name used to identify an <tt>Exception</tt>.
40
 * @type {String}
41
 * @default
42
 */
43 1
Exception.prototype.name = "Exception";
44
45
// :: EXPORT
46
47
// export the Exception 'class'
48
module.exports = Exception;